class Solution {
public:
    void helper(vector<int>& nums,vector<vector<int>>& res,int first){
        int len=nums.size();
        if(len==first)
            res.emplace_back(nums);
        for(int i=first;i<len;i++){
            swap(nums[i],nums[first]);
            helper(nums,res,first+1);
            swap(nums[i],nums[first]);
        }
    }
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>> res;
        helper(nums,res,0);
        return res;
    }
};
